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(57) ABSTRACT 

A distributed computer aided design (CAD) system includes 
a CAD server station and one or more CAD client stations 
remote from the server station but connectable thereto via a 
communications medium such as an intranet or the internet. 
The CAD server station includes a CAD tool for performing 
CAD tasks and a communications interface. The CAD client 
stations include display and data entry facilities for display- 
ing a design parameter entry document to a user and for 
accepting design parameters entered by the user, as well as 
a communications interface for transmitting entered design 
parameters via the communications medium to the server 
station. The CAD tool at the server station is configured to 
receive the design parameters from the client station, to 
perform CAD tasks based on the design parameters and to 
return processed design data to the server station via the 
communications medium. The client station can include a 
workstation with a web browser capability. The server 
station can be configured to respond to a request from a 
client station to supply a design parameter input form. 
Integrated circuit design can be performed by providing 
circuit design executables and circuit design libraries (e.g for 
memory cells) at the CAD tool. The CAD tool can also 
provide simulation tools. 

15 Claims, 6 Drawing Sheets 
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DISTRIBUTED COMPUTER AIDED DESIGN 
SYSTEM AND METHOD 

BACKGROUND OF THE INVENTION 

The invention relates to computer aided design systems 5 
and methods. 

Traditionally, computer aided design tools and the asso- 
ciated design libraries reside on a user's computer system, 
either a workstation or personal computer, or a local J(J 
(nearby) computer mainframe or fileserver at the user's 
location or within the user's local computer system. A 
sophisticated user-machine interface then permits the user to 
enter data into the CAD tool to enable that tool to process 
and display results, error messages, and so on to the user. If 
the user concerned is not the person responsible for main- 
taining the computer aided design tool (for example where 
the user concerned is not at the location where the CAD tool 
is created and maintained), it is necessary for the user to 
receive the CAD tool executables and libraries and to „ rt 

20 

maintain his local copy. In a rapidly changing environment, 
frequent changes to the CAD tool may become necessary. 
FIG. 1 of the accompanying drawings is a schematic rep- 
resentation of this scenario where the CAD tools mainte- 
nance location 12 has to send copies of the relevant tools 14 25 
(by physical or electronic means, as appropriate), to the 
relevant user CAD locations 16. 

The disadvantages of this conventional approach of keep- 
ing local CAD tools can be summarised as follows: 

1. CAD tool executables change frequently and the user 30 
must keep updating his local copy. 

2. In turn, this means that the designers/maintainers of a 
CAD tool must send out multiple copies once a significant 
update has been made to the CAD tool concerned. 

3. Libraries referred to by the executable are also changed 35 
frequency. Accordingly, the user must continue to update 
his local copies and the designers/maintainers of the CAD 
tool libraries must continue to send out multiple copies 
once significant updates have been made. 

4. CAD designers/maintainers are reluctant to send out 40 
updates following minor tool or library updates due to the 
logistical overheads involved as indicated above. 
Accordingly, a user's local CAD tool and associated 
library can rapidly get out of date. 

5. File storage must be available for the CAD tool 45 
executables and associated library at the user's location. 
Some CAD executables and libraries are used 
infrequently, but will nevertheless have to be backed up 
and maintained as any other piece of software at the user's 
location. 50 

6. The local computer power made available to the user must 
exceed the maximum requirements for acceptable perfor- 
mance during the execution of the CAD tool, which can 
significantly increase the cost of a user's computing 
requirements. 55 
Accordingly, it is an aim of the present invention to 

provide a solution which at least mitigates the various 
problems and disadvantages of the conventional CAD 
approach set out above. 

SUMMARY OF THE INVENTION 60 

In accordance with an aspect of the invention, there is 
provided a distributed computer aided design system com- 
prising: 

a computer aided design server station including a com- 65 
puter aided design tool for performing computer aided 
design tasks and a communications interface; and 
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one or more computer aided design client stations remote 
from the server station and connectable to the server 
station via a communications medium, a client station 
comprising display and data entry means for displaying 
a design parameter entry document to a user and for 
accepting design parameters entered by the user and a 
communications interface for transmitting the design 
parameters via the communications medium to the 
server station; 

the computer aided design tool at the server station being 
configured to receive the design parameters from the 
client station, to perform computer aided design tasks 
based on the design parameters and to return a design 
task product to the server station via the communica- 
tions medium. The design task product can comprise, 
for example, a file comprising parameters specifying a 
resulting design, for example, of a circuit for an inte- 
grated circuit. 

An embodiment of the invention can provide significant 
advantages over the conventional CAD approach described 
earlier: 

1. No local copy of the CAD tool executable needs to be kept 
on the user's system. Accordingly, whenever the CAD 
tool executable is changed by the CAD designers/ 
maintainers, only the master copy on the server station 
needs to be updated. 

2. Updates are consequently only necessary at the server 
station and the need for distributing multiple copies is no 
longer required. 

3. The same benefits as indicated at 1 and 2 also apply to 
CAD tool libraries. 

4. CAD designers/maintainers will be encouraged to update 
the master copy much more regularly in view of the 
reduced logistics in this process. 

5. The file storage for the CAD tool executables and libraries 
is only necessary at the server station, and only the master 
copy of this needs to be backed up. Users are therefore 
relieved of the requirement to maintain the CAD tool 
executables and libraries. 

6. A consequence of the above is that only the server station 
needs to be provided with the computing power for 
providing acceptable performance during execution of the 
CAD tool. Preferably, this is able to handle multiple users, 
possibly in a batch, or alternatively in a coprocessing 
manner. 

In a preferred embodiment of the invention, the commu- 
nications medium is an intranet or internet medium. In such 
an embodiment a cost effective implementation of a client 
station is in the form of a computer workstation having web 
browser capability. 

The client station can be arranged to generate its own 
parameter entry forms. However, it is advantageous for the 
server station to be configured to respond to a request 
communicated from a client station to supply a design 
parameter input form to the client station. This ensures that 
the parameter input form used; takes account of all input 
parameter requirements of the design tool concerned. 

A preferred embodiment of the invention provides inte- 
grated circuit design functions. In this case, the computer 
aided design tool comprises circuit design executables and 
circuit design libraries, the circuit design executables being 
responsive to the design parameters to access the circuit 
design libraries automatically to perform the circuit design. 
A specific example of this which is particularly suitable for 
parameterised design specification provides memory design 
executables and memory design, libraries. 

The computer aided design tool can also provide simu- 
lation tools. 
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The invention also provides a computer aided design or internet medium. Other network mediums could be used, 

server station for a distributed computer aided design system However, in the present computing environment, the use of 

as set out above, the server station comprising a computer an intranet or internet provides an ideal vehicle for imple- 

aided design tool for performing computer aided design task menting an example of the present invention, 

and a communications interface whereby the server station 5 As illustrated schematically in FIG. 2, the server station 

is connectable to at least one computer aided design client comprises an intranet/internet interface 32 including a 

station remote from the server station via a communications modem 33 for connection to the communications medium 

medium, the computer aided design tool at the server station v ia a link 23. A computer 30, which includes a central 

being configured to receive design parameters from a client processing unit, associated main and mass storage memory 

station via the communications medium, to perform com- 10 anc j a ll the other typical attributes of a computer, supports a 

puter aided design tasks based on the design parameters and number of applications including a network monitor appli- 

to return a design task product to the server station via the cation 34, management applications 36 and a computer 

communications medium. aided design tool 38, including design tool executables 37 

The invention further provides a method of conducting (programs) and design tool libraries 39. One or more user 

computer aided design at a client station for a distributed 15 stations 28 including a display, (possibly a local processor) 

computer aided design system as set out above, the method anc j input/ output devices can be provided for CAD tool 

comprising, at said client station, displaying a design param- designers/maintainers to create and maintain the CAD tool 

eter entry document to a user, accepting design parameters 38. 

entered by the user, transmitting the design parameters via A , a ^ SMjm 26 , w[ ^ ided with , ter 

the communications medium to a remote computer aided 20 workstation 40 having a disp i a y 42> user input devices 44, a 

design server station for performing computer aided design ^ 4fi ^ associsi]ed m etc> and a Detwork 

tasks on the design parameters, and receiving a design task imerface 4g includj a modem ^ usef . s workstation 40 

product via the communicauons medium from the server is ako ptoM< jn tne preferred embodiment of the 

station. invention, with network browser software which is stored in 

In accordance with another aspect of the invention there 25 , he workstation > s memory and executed on , he worksta . 

is provided a method of performing computer aided design nmnpecnn2 

. * j ^ 1- lion s processors. 

0?^™™^?^^;^^ j^^,^ 0 „, t „ 0 „ cor ot , It will be noted that any number of client stations can be 

a) presenting a design parameter document to a user at a ... . t w L . 

client computer aided design station; f K oanecte u d t0 ^ server ** Uoa ™u ^T* ™' 

b) following input of the computer aided design parameters, 30 the number * cl,enl stat t I0 , nS wh * h K can mak e , al «? 
( «ncm,- t tt, n tu« ™ a :A„A A^; nn , o one Ume to lne server station will be limited by the band- 
transmitting the computer aided design parameters via a . . , _ . . ^„ , . , 1 ^ 

, • f t - 0 ^Ji,™ <~ „ \ „ t _ > A . width of the server station 22, and possibly the network 24. 

communications medium to a remote computer aided r J 

design server station including a computer aided design FIG 3 is a thematic representation of the use of the 

tool for performing computer aided design tasks; svstem 38 shown in FIG 2 - In lhe P referred embodiment, the 

c) automatically performing computer aided design tasks in 35 svstem operates by running CAD programs on the server 
response to the design parameters; and station ^th the user gaining access to those programs from 

d) transmitting a design task product to the server station via his/her client station over the world ^ web fatranet 
the communications medium. and/or interae 0- Access is achieved through the use of 

"forms" for defining parameters of a CAD task to be 

DESCRIPTION OF THE DRAWINGS 40 performed. 

The user interacts with a standard WEB page that captures 

An exemplary embodiment of the invention is described his design requirements> for example by use of a software 

hereinafter, by way of example only, with reference to the form 51 ^ form can be generaled locally at the client 

accompanying drawings in which like reference signs relate station> 5ut pre f e rably this is received from the server station 

to like parts and in which: ^ when the ^ accesses a web page at that se^r station . 

FIG. 1 is a schematic representation of a conventional Accordingly, this provides the advantage that the server 

distributed system for computer aided design; station can keep the forms up-to-date, and the user receives 

FIG. 2 is a schematic representation of an example of a the latest version of the form when he/she wishes to make 

distributed computer aided design system in accordance use of CAD tool functions. 

with the invention; 50 Once the user has received and completed the form, 

FIG. 3 is a further schematic representation of the system he/she then submits (52) the form by effectively sending the 

of FIG. 2 for illustrating the flow of information; contents of the fields he/she has just entered over the inter- 

FIG. 4 is a flow diagram representing operations per- or intranet to ^ CAD server, which is at a location remote 

formed at a client station for the system of FIG. 2; from lhe user ' s location. The CAD server then processes 
, t . c .55 (54) the data received (e.g. performs some form of analysis, 

FIG. 5 is a schematic representation of a parameter input v . . , • A u »u ♦ i ^\ 

c c t A . i« . » c i-i^ a j synthesis or simulation, as required by the task concerned) 

form for use at the client station of FIG, 4; and J ... , /r£N ,, ' 7/ . J .. . c 7 

and then returns (56) the results to the user, either in the form 

FIG. 6 is a flow diagram illustrating the operation of the of some texlual or & ^ hic& i information, or as a file repre- 

server station of FIG. 2. senting a completed design, for example, a file containing 

DESCRIPTION OF A PREFERRED 60 P"" 5 of a circuit design or circuit cell design for an 

rwnrimwrvrr integrated circuit. It will be appreciated that the user client 

hMBODIMENI i j az • * ^ «i_ u 

station thus only needs sufficient power to support the web 

FIG. 2 is a schematic overview of an example of a browser capability. However, the client station can also be 

computer aided design system in accordance with the provided with sufficient computing power for performing 

present invention. As shown in FIG. 2, a server station 22 65 further CAD tasks. Thus, it is possible that the remote server 

communicates with the plurality of client stations 26 via a station is used for performing specific tasks, for example for 

communications medium 24, which is preferably an intranet defining the parameters of part of an overall design, which 
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the user then incorporates in the full design which is being 
performed at his/her client station. 

FIG. 4 is a flow diagram illustrating an example of the 
operations which might be performed by the user at a client 
station. 5 

In Step CI, the user employs web browser software 
supported by the client station to access a web page sup- 
ported by the server station. The process of accessing the 
web page can involve providing suitable security clearance 
(for example passwords) in order that only authorised users 10 
gain access. 

In Step C2, the user can select an appropriate form for 
carrying out the CAD task required. For example, where the 
user is designing an integrated circuit, he/she might use a 
CAD tool with associated executable libraries which enable 
the designing of a memory or memory cell for incorporation 
into his/her integrated circuit design. Once again, at this 
stage, security can be provided (for example through the use 
of passwords) to ensure that only authorised users gain 2Q 
access to the forms. 

The form is then downloaded by the server to the client 
station so that, in Step C3, the user is able to enter the 
various parameters of the design concerned. FIG. 5 is a 
schematic representation of a web form which might be 2 5 
supplied from the server station to the client station. It will 
be seen that various parameters of a memory cell are 
indicated, for example a cell name, compiler type, number 
of words, number of bits, column options, operating 
frequency, and so on. The form can be associated with 30 
appropriate prompt software, as will be apparent to one 
skilled in the art, to ensure that the user correctly completes 
the form. 

Once the user has correctly completed the form., this can 
then be sent in Step C4 to the server station. Typically, this 35 
is performed by the form software selecting the parameters 
as entered by the user, and transmitting those parameters to 
the server station in a conventional manner. 

All the user then has to do is wait until the server station 
has completed processing the tasks required, and returns the 40 
results in the form of textual, graphical, or parametric form, 
as appropriate, typically in the form of a computer file. 
Following receipt of the results in Step C5, the user can use 
those data in an appropriate manner, for example by incor- 
poration into his/her local integrated circuit design in Step 45 
C6. 

FIG. 6 is a flow diagram representing the functions 
performed by the server station. 

In Step SI, the server station idles waiting for a message 5Q 
requesting access to the web page supported by the server 
station. 

When access to the web page is requested, and subject to 
optional identification procedures, the web page can be 
supplied to the user in Step S2, including subsequently 55 
requested pages, for example a specific form associated with 
a CAD task. 

When the parameters relating to a completed CAD task 
parameter form are received in Step S3, security checks are 
performed, as appropriate, and subject to correct g 0 
authorization, the job description concerned is created and 
the details thereof are stored for later use in Step S4, The 
appropriate CAD task is launched in Step S5 and this 
process continues until the results are generated at Step S6. 

In Step S7, the results are returned as a file to the user 65 
making use of the details for the job which were stored in 
Step S4. 



The server station can also perform billing tasks, in a 
conventional manner, and can include the billing informa- 
tion with the returned data, or can process this separately as 
required. 

Accordingly, a distributed CAD tool has been described 
whereby tasks such as synthesis, compilation, simulation 
and so on, which do not require "real-time" interaction with 
the tool are performed on a server station which is remote 
from a client station where a user is located. The server can 
be implemented by a powerful workstation, or by a mid-size 
or mainframe computer, as appropriate. The processing of 
CAD tasks can be performed in a batch process, or in a 
multi-processing environment, as desired, and as depending 
on a particular implementation of the server station. Rather 
than the simple process described above where a design tool 
performs a task and then immediately returns the results to 
the user, the results could be stored at the server for later 
transmission to the user. Alternatively, the results of the tasks 
performed by one CAD tool could form an input file for a 
further CAD tool, and so on. Using an embodiment of the 
invention, it will be possible to carry out a complete inte- 
grated circuit design with the user concerned, with the user 
merely requiring access to a workstation or other computer 
providing a web browser and a modem connection. Indeed, 
it is possible for the client station to be linked directly to a 
fabrication process for producing an integrated circuit 
according to said design. 

Although a particular embodiment of the invention has 
been described, it will be appreciated that many modifica- 
tions and/or additions may be made thereto without depart- 
ing from the scope of the invention. 

What is claimed: 

1. A distributed computer aided design system compris- 
ing: 

a server station including (i) a computer aided design tool 
for performing a plurality of computer aided design 
tasks and (ii) a communications interface; and 

one or more client stations remote from said server station 
and connectable to said server station via a communi- 
cations medium, each of said client stations comprising 
(i) a display for displaying a parameter input form to a 
user, (ii) an input device for accepting a plurality of 
design parameters entered by said user and (iii) a 
communications interface for transmitting said design 
parameters via said communications medium to said 
server station; 

wherein (a) said server station is configured to respond to 
a request communicated from said client stations to 
supply said parameter input form, (b) said computer 
aided design tool is configured to (i) receive said design 
parameters from said client station, (ii) perform at least 
one of said computer aided design tasks based on said 
design parameters and (iii) return a design task product 
to said client station via said communications medium 
and (c) said computer aided design tool comprises (i) a 
plurality of circuit design executables and (ii) a plural- 
ity of circuit design libraries, said circuit design 
executables being responsive to said design parameters 
to access said circuit design libraries automatically to 
perform a circuit design, 

2. The system according to claim 1, wherein said com- 
munications medium is an intranet or internet medium. 

3. The system according to claim 1, wherein each of said 
client stations further comprise a computer workstation 
having web browser capability. 

4. The system according to claim 1, wherein said com- 
puter aided design tool further comprises: 



07/27/2004, EAST version: 1.4.1 



US 6,397, 

7 

a plurality of memory design executables; and 
a plurality of memory design libraries. 

5. The system according to claim 1, wherein said com- 
puter aided design tool comprises a simulation tool. 

6. A method of performing computer aided design com- 5 
prising the steps of: 

(A) supplying a parameter input form from a server 
station to a client station remotely located from said 
server station in response to a request from said client 
station; 10 

(B) presenting said parameter input form to a user at said 
client station; 

(C) transmitting a plurality of computer aided design 
parameters via a communications medium from said ^ 
client station to a computer aided design tool of said 
server station, wherein said computer aided design tool 
comprises (i) a plurality of integrated circuit design 
executables and (ii) a plurality of circuit design librar- 
ies; 20 

(D) automatically performing at least one of a plurality of 
computer aided design tasks in response to said design 
parameters; 

(Dl) accessing said circuit design libraries automatically 
with said integrated circuit design executables respon- 25 
sive to said design parameters to perform a circuit 
design; and 

(E) transmitting a design task product to said client station 
via said communications medium. 

7. The method according to claim 6, wherein said com- 30 
munications medium is an intranet or internet medium. 

8. The method according to claim 7, wherein Step (A ) 
comprises the sub-steps of: 

accessing said server station from said client station via 35 
said communications medium using a web browser; 
and 

receiving said parameter input form at said client station 
from said server station. 

9. The method according to claim 6, wherein said com- 40 
puter aided design tool further comprises a plurality of 
memory design executables and a plurality of memory 
design libraries. 

10. The method according to claim 6, wherein Step (D ) 
comprises the sub-step of performing a design simulation 45 
task. 

11. A method of conducting computer aided design, 
comprising the steps of: 
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(A) providing a distributed computer aided design system 
which includes a server station having (i) a computer 
aided design tool for performing a plurality of com- 
puter aided design tasks and (ii) a communications 
interface, wherein said computer aided design tool 
comprises (i) a plurality of circuit design executables 
and (ii) a plurality of circuit design libraries; 

(B) providing a client station remote from said server 
station and connectable to said server station via a 
communications medium, said client station including 

(i) a display for displaying a parameter input form to a 
user, (ii) an input device for accepting a plurality of 
design parameters entered by said user, and (iii) a 
communications interface for transmitting said design 
parameters via said communications medium to said 
server station; 

(C) configuring said server station to supply said param- 
eter input form to said client station in response to a 
request from said client station; 

(D) configuring said computer aided design tool to (i) 
receive said design parameters from said client station, 

(ii) perform at least one of said computer aided design 
tasks based on said design parameters, (iii) accesses 
said circuit design libraries automatically with said 
integrated circuit design executables responsive to said 
design parameters to perform a circuit design, and (iv) 
return a design task product to said client station via 
said communications medium; and 

(E) configuring said client station to (i) display said 
parameter input form to said user, (ii) transmit said 
design parameters via said communications medium to 
said server station, and (iii) receive said design task 
product via said communications medium from said 
server station. 

12. The method according to claim 11, wherein said 
communications medium is an intranet or internet medium. 

13. The method according to claim 12, wherein said client 
station comprises a computer workstation having web 
browser capability. 

14. The method according to claim 11, wherein said 
computer aided design tool further comprises a plurality of 
memory design executables and a plurality of memory 
design libraries. 

15. The method according to claim 11, wherein said 
computer aided design tool comprises a simulation tool. 

***** 
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